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Response to Amendment 
L Claims 45-54 are newly added claims. Claims 1-54 are pending this application. 

Specification 

2. The objection to the specification is now withdrawn. 

Response to Arguments 

3. Applicant's arguments filed March 30, 2003 have been fully considered but are not 
persuasive. 

In the remarks, applicant argues in substance that (1) Hervin patent makes no reference to 
a minimum state saving a minimum state, (2) Hervin does not disclose altering a program 
counter of an executing service, (3) Hervin patent does not disclose a checksum error or 
checking for a checksum error; (4) Hervin patent does not disclose setting a breakpoint at a last 
safe point or simulating instruction of the executing service from the last safe point to the 
breakpoint. 

4. In response to applicant's arguments, the Examiner respectfully disagrees, (1) - (4); (1) 
Hervin saves the state of the processor in Col. 6, lines 1-3 where the write back stage stores the 
processor state in a register file; Also see Col. 13, lines 3-23 for the use of the System 
Management Mode where certain portions of the processor state or minimum state is saved. The 
SMI routine that is executed is user definable so the user may define the state information of the 
processor to be saves. Also see Col. 13, lines 37-41 where the routine does not interfere with the 
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operating system or application programs; (2) Hervin et al. teaches a breakpoint counter is 
programmable or can be altered, See Col. 10, lines 15-37, for an alterable counter; (3) See Col. 1, 
lines 10-15 for the diagnosing and debugging of errors in a processor's execution being crucial to 
the system performance. Also see Col. 8, lines 56-67 for analyzing an error and checking for an 
error. (4) See abstract for a set of debug registers that identify a debug exception by setting 
breakpoints. Hervin et al. Allows setting multiple breakpoints using breakpoint registers and 
simulating the executing service from one breakpoint to another. Also See Col. 4, lines 24-32 
for controlling of the instruction stream and determining which instructions cause exceptions or 
are unsafe instructions. 

Claim Rejections - 35 USC § 102 
5. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 102 that form the 
basis for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 

(e) the invention was described in a patent granted on an application for patent by another filed in the United 
States before the invention thereof by the applicant for patent, or on an international application by another who 
has fulfilled the requirements of paragraphs (1), (2), and (4) of section 371(c) of this title before the invention 
thereof by the applicant for patent. 

The changes made to 35 U.S.C. 102(e) by the American Inventors Protection Act of 1999 
(AIPA) do not apply to the examination of this application as the application being examined 
was not (1) filed on or after November 29, 2000, or (2) voluntarily published under 35 U.S.C. 
122(b). Therefore, this application is examined under 35 U.S.C. 102(e) prior to the amendment 
by the AIPA (pre-AIPA 35 U.S.C. 102(e)). 
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6. Claims 1-7, 9-24, 26-28, 31-54 are rejected under 35 U.S.C. 102(e) as being 
anticipated by Hervin et al., U.S. Patent No. 6,205,560. 

As per Claims 1, 17, 37-40, and 42-43, Hervin et al., disclose a method of debugging an 
executing service on a pipelined CPU architecture, the method comprising: 

setting a breakpoint within an executing service (See Col 4, lines 32-42 for setting and 
identifying breakpoints); 

saving a minimum state of the executing service (See Col. 6, lines 1-3 where the write 
back stage stores the processor state in a register file); 

altering a program counter of the executing service (See Col. 10, lines 15-37, for an 
alterable counter); 

restoring the program counter of the executing service(See Col. 10, lines 15-37, for an 
alterable counter therefore it is able to go back to a saved value); and 

restoring the state of the executing service (See Col. 6, lines 1-3 where the write back 
stage stores the processor state in a register file. A state written to a register file may be restored 
from the register file). 

As per Claim 2, Hervin et al., disclose a executing debug commands within the executing 
service (See Abstract for executing debug commands for executing instructions). 

As per Claims 3 and 19, Hervin et al., disclose locating an original instruction within the 
executing service to set the breakpoint (See Col. 2, lines 1-9 where Breakpoints are set at 
specific or original instructions or data in a program); 
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inserting a breakpoint instruction at the breakpoint (See Col. 2, lines 1-9 where 
breakpoints halt the program and shift the program's operation to the debug interrupt handlers 
i.e. the function of a breakpoint instruction); 

starting the executing service (See Col. 2, lines 1-9 where breakpoints halt the program 
and shift the program's operation to the debug interrupt handlers i.e. start the execution); 

waiting for the breakpoint to execute (See col. 4, lines 23-32 for the pipe control unit that 
keeps track of the earliest instructions, provides a stall output, and receives a delay input, i.e. 
waits for the breakpoint to execute); 

waiting for memory fetches and configuration loads to complete (See Col. 6, lines 15-20 
for the Memory/Bus controller that allows the breakpoint exception to complete); and 

restoring the original instruction at the breakpoint location (See Col. 6, lines 1-3 where 
The write back WB stage updates the register file 24, condition codes, and other parts of the 
machine state with the results of the previously executed instruction therefore the processor has 
the information to restore the original instruction at the breakpoint location). 

As per Claim 4, Hervin et al., disclose a altering an instruction within the executing 
service at a breakpoint location (See Col. 2, lines 46-50 for generating an exception that can go 
to many locations, therefore the instruction at the breakpoint is altered); 

invalidating a page cache of the executing service (See Col. 5, lines 42-51 for cache 
address enablement, therefore, the cache can be invalidated). 

As per Claims 5 and 21, Hervin et al., disclose a setting a breakpoint register to point to a 
breakpoint location (See Table 3, Definition of Debug Configuration Registers, Col 9 lines 10-45 
for breakpoint registers). 




Application/Control Number: 09/539, 1 97 Page 6 

Art Unit: 2123 

As per Claim 6, Hervin et al., disclose saving the executing service registers (See Col. 6, 
lines 1-3 where the write back stage stores the processor state in a register file, since the register 
values determine the state, the register values are also saved); 

and flushing a pipeline of the executing service (See Col. 4, lines 23-42 for the pipe 
control unit that flushed the pipeline). 

As per Claim 7, Hervin et al., disclose determining if registers are unstable (See Figure 
14 and text in Col. 18, lines 34-55, for the SMI interrupt for when the processor hangs, or the 
processor and registers are unstable); 

if registers are unstable, saving the value of any registers that change after each pipeline 
cycle (See Col. 1, lines 19-29 for execution, the execution unit of the microprocessor uses a 
number of general purpose registers and control registers to write/read data or store control 
information. The data and/or control information at any point in time stored in the 
microprocessor, along with other information being used by the microprocessor, such as the 
instruction being fetched is called the processor state. Therefore, Hervin et al. disclose saving 
and restoring register values as part of saving and restoring the processor state); and 

if the breakpoint location is set on a location that uses old values of registers, saving the 
old values of the registers before new values are written to the registers (See Col. 18, lines 34-55 
for saving the processor state and system management mode so the program can return to that 
state or mode). 

As per Claims 9-10 and 26-27, Hervin et al., disclose setting the program counter of the 
executing service to point to a save stub (See Figure 5 and Col. 10, lines 10-37, for the break 
point program counter); 
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starting execution of the executing service (See Figure 6, and text in Col. 10, lines 38-67 
for starting the execution); 

executing the breakpoint (See Figure 6, and text in Col. 10, lines 38-67 for starting the 
execution, step 110 enabling the breakpoint); 

storing configuration registers of the executing service (See Col. 6, lines 1-3 where the 
write back stage stores the processor state in a register file, storing register values is part of 
storing the processors state); 

saving values of scalar and predicate registers(See Col. 6, lines 1-3 where the write back 
stage stores the processor state in a register file, storing register values is part of storing the 
processors state); 

saving pipeline registers(See Col. 6, lines 1-3 where the write back stage stores the 
processor state in a register file, storing register values is part of storing the processors state); and 

storing a stack pointer value for a breakpoint location (See Col. 6, lines 1-3 where the 
write back stage stores the processor state in a register file, storing the stack pointer is part of 
storing the processors state). 

As per Claims 11, 24, and 28, Hervin et al., disclose if a breakpoint location is on an 
instruction that does not make use of old values, restoring stable registers (See Col. 6, lines 40- 
58 for the breakpoint instruction does not make use of old values so a fault exception is 
generated); 

if the breakpoint location is on an instruction that does make use of old values, 
restoring unstable registers, and reloading the pipeline(See Col. 6, lines 40-58 for the breakpoint 
instruction does not make use of old values so a trap exception is generated); 
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altering the program counter of the executing service to point to the breakpoint location; 
and starting execution of the executing service at the breakpoint location (Figure 3, and text in 
Col. 6, lines 40-58 for the breakpoint instruction does not make use of old values so a trap 
exception is generated). 

As per Claims 12, 16, 31-32, 36, 41, and 44, Hervin et al., disclose fetching a page of 
memory of the executing service into an instruction cache (See Col. 4, lines 49-56 for the 
instruction fetch stage); 

checking for a checksum error within the page of memory (See Col 5, lines 1-18 for 
instruction decode stage that checks for errors in the instructions fetched from memory); and 

if the executing service is set to reject the checksum error, saving the page of memory, 
inserting a breakpoint into the saved page of memory, altering an instruction pointer to the saved 
page of memory, and processing the saved page of memory (See Col 8, lines 56-67 for an error 
in a group of instructions to set breakpoints and further debug the error). 

As per Claims 13 and 33, Hervin et al, disclose a method of debugging an executing 
service on a pipelined CPU architecture, the method comprising: 

setting a breakpoint at a last safe point (See Col. 4, lines 32-42 for setting and identifying 
breakpoints); 

saving a minimum state of the executing service (See Col. 6, lines 1-3 where the write 
back stage stores the processor state in a register file); 

simulating instructions of the executing service from the last safe point to the breakpoint 
(See Col. 8, lines 44-67 for regaining control of the program from the last breakpoint set); 
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executing debug commands within the executing service (See Col. 8, lines 44-67 for 
executing debug commands); and 

restoring the state of the executing service (See Col. 6, lines 1-3 where the write back 
stage stores the processor state in a register file. A state written to a register file may be restored 
from the register file). 

As per Claims 14 and 34, Hervin et al., disclose storing the simulated state of the 
executing server to the CPU (See Col. 6, lines 1-3 where the write back stage stores the 
processor state in a register file); 

and restoring an original execution (See Col. 6, lines 1-3 where the write back stage 
stores the processor state in a register file. A state written to a register file may be restored from 
the register file). 

As per Claims 15 and 35, Hervin et al., disclose comprises single stepping through a set 
of unsafe instructions, the set of unsafe instructions are between the last safe point and a next 
safe point (See Col. 8, lines 56-67 for the logical analyzer setting breakpoints in debug address 
register for all the instructions which helps to single step through a group of instructions). 

As per Claim 18, Hervin et al., disclose a debugger to set a breakpoint within an 
executing service and execute debug commands within the executing service (See Abstract for a 
debugger for executing debug commands); 

a save stub to save a minimum state of the executing service (See Col. 6, lines 1-3 where 
the write back stage stores the processor state in a register file) and alter a program counter of the 
executing service (See Col. 10, lines 15-37, for an alterable counter); 



Application/Control Number: 09/539,197 Page 10 

Art Unit: 2123 

a processing engine to execute the breakpoint (See Abstract for a processing engine for 
debugging with breakpoints); 

and a restore stub to restore the state of the executing service (See Col. 6, lines 1-3 where 
the write back stage stores the processor state in a register file. A state written to a register file 
may be restored from the register file). 

As per Claim 20, Hervin et aL, disclose a debugger is further operable to alter a page 
cache of the executing service (See Col. 4, lines 49-56 for fetching instruction and data into a 
cache, therefore the debugger can alter the cache). 

As per Claim 22, Hervin et aL, disclose saving the executing service registers (See Col. 6, 
lines 1-3 where the write back stage stores the processor state in a register file). 

As per Claim 23, Hervin et al., disclose flushing a pipeline of a set of pipeline 
instructions of the executing service (Col. 4, lines 23-32 for the pipeline control unit for flushing 
the pipeline). 

As per Claim 45-54, Hervin et al, disclose saving the minimum state further comprises 
saving a minimum amount of the executing service that can be restored to halt and restart 
execution of the service without altering the behavior of the executing service (Col. 13, lines 3- 
23 for the use of the System Management Mode where certain portions of the processor state or 
minimum state is saved. The SMI routine that is executed is user definable so the user may 
define the state information of the processor to be saves. Also see Col. 13, lines 37-41 where the 
routine does not interfere with the operating system or application programs). 
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7. Claims 8, 25, 29-30 are objected to as being dependent upon a rejected base claim, but 
would be allowable if rewritten in independent form including all of the limitations of the base 
claim and any intervening claims. 

Conclusion 

8. Applicant's amendment necessitated the new ground(s) of rejection presented in this 
Office action. Accordingly, THIS ACTION IS MADE FINAL. See MPEP § 706.07(a). 
Applicant is reminded of the extension of time policy as set forth in 37 CFR 1 .136(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within TWO 
MONTHS of the mailing date of this final action and the advisory action is not mailed until after 
the end of the THREE-MONTH shortened statutory period, then the shortened statutory period 
will expire on the date the advisory action is mailed, and any extension fee pursuant to 37 
CFR 1 . 136(a) will be calculated from the mailing date of the advisory action. In no event, 
however, will the statutory period for reply expire later than SIX MONTHS from the date of this 
final action. 

9. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Samarina Makhdoom whose telephone number is 703-305-7209. 
The examiner can normally be reached on Full Time on Friday and Saturday. 
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If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Kevin J. Teska can be reached on 703-305-9704. The fax phone numbers for the 
organization where this application or proceeding is assigned are 703-305-0040 for regular 
communications and 703-305-0040 for After Final communications. 

Any inquiry of a general nature or relating to the status of this application or proceeding 
should be directed to the receptionist whose telephone number is 703-305-3900. 

SM 

May 15, 2003 




